如何匹配位置呢?
^
$
\b
\B
(?=p)
(?!p)
^
和 $
^(脱字符)匹配开头,在多行匹配中匹配行开头。
$(美元符号)匹配结尾,在多行匹配中匹配行结尾。
比如我们把字符串的开头和结尾用”#”替换(位置可以替换成字符的!):
1 | var result = "hello".replace(/^|$/g, '#'); |
多行匹配模式时,二者是行的概念,这个需要我们的注意:
1 | var result = "I\nlove\njavascript".replace(/^|$/gm, '#'); |
\b
和 \B
b
是单词边界,具体就是\w
和\W
之间的位置,也包括\w
和^
之间的位置,也包括\w
和$
之间的位置。
比如一个文件名是”[JS] Lesson_01.mp4”中的\b
,如下:
1 | var result = "[JS] Lesson_01.mp4".replace(/\b/g, '#'); |
为什么是这样呢?这需要仔细看看。
首先,我们知道,\w
是字符组[0-9a-zA-Z_]
的简写形式,即\w
是字母数字或者下划线的中任何一个字符。而\W
是排除字符组[^0-9a-zA-Z_]
的简写形式,即\W
是\w
以外的任何一个字符。
此时我们可以看看”[#JS#] #Lesson_01#.#mp4#”中的每一个”#”,是怎么来的。
- 第一个”#”,两边是”[“与”J”,是
\W
和\w
之间的位置。 - 第二个”#”,两边是”S”与”]”,也就是
\w
和\W
之间的位置。 - 第三个”#”,两边是空格与”L”,也就是
\W
和\w
之间的位置。 - 第四个”#”,两边是”1”与”.”,也就是
\w
和\W
之间的位置。 - 第五个”#”,两边是”.”与”m”,也就是
\W
和\w
之间的位置。 - 第六个”#”,其对应的位置是结尾,但其前面的字符”4”是
\w
,即\w
和$
之间的位置。
知道了\b
的概念后,那么\B
也就相对好理解了。\B
就是\b
的反面的意思,非单词边界。例如在字符串中所有位置中,扣掉\b,剩下的都是\B的。
具体说来就是\w
与\w
、\W
与\W
、^
与\W
,\W
与$
之间的位置。比如上面的例子,把所有\B
替换成”#”:
1 | var result = "[JS] Lesson_01.mp4".replace(/\B/g, '#'); |
(?=p)
和 (?!p)
(?=p)
,其中p
是一个子模式,即p
前面的位置。
比如(?=l)
,表示’l’字符前面的位置,例如:
1 | var result = "hello".replace(/(?=l)/g, '#'); |
而(?!p)
就是(?=p)
的反面意思,比如:
1 | var result = "hello".replace(/(?!l)/g, '#'); |
二者的学名分别是positive lookahead和negative lookahead。
中文翻译分别是正向先行断言和负向先行断言。
ES6中,还支持positive lookbehind和negative lookbehind。
具体是(?<=p)和(?<!p)。
也有书上把这四个东西,翻译成环视,即看看右边或看看左边。
但一般书上,没有很好强调这四者是个位置。
位置的特性
把位置理解空字符,是对位置非常有效的理解方式
1 | var result = /^^hello$$$/.test("hello"); |
相关案例
1 | // 不匹配任何东西的正则 |
1 | // 弄出最后一个逗号 |
1 | // 弄出所有的逗号 因为逗号出现的位置,要求后面3个数字一组,也就是\d{3}至少出现一次 此时可以使用量词+ |
1 | // 不是期望的结果 |
1 | // 如果要把"12345678 123456789"替换成"12,345,678 123,456,789"。 |
1 | // 密码长度6-12位,由数字、小写字符和大写字母组成 |
以上信息仅做笔记记录,如有冒犯,请联系我。感谢老姚,附作者掘金地址链接: https://juejin.im/post/59cc61176fb9a00a437b290b